Docket No. AUS920011026US1 



APPARATUS AND METHOD OF COMBINING BOOKMARKS IN DIFFERENT 
SUB-FOLDERS INTO A NEW SUB-FOLDER 

CROSS-REFERENCE TO RELATED APPLICATIONS 



5 



This application is related to co-pending US Patent 
Application Serial No . O^Iq^1 9i5 /^"^m" ^^'^^^ocket No. 
AUS920010888US1) , entitled APPARATUS AND METHOD OF 
ORGANIZING BOOKMARKED WEB PAGES INTO CATEGORIES by the 
10 inventors herein, filed on even date herewith and assigned 
to the common assignee of this application. 



This application is also related to co-pending US 
^1^^^ Patent Application Serial No . s^/^?^ j^ ^J^l^vT "i^Jket No. 
15 AUS920011025US1) , entitled APPARATUS AND METHOD OF LINKING 
SUB-FOLDERS IN A BOOKMARK FOLDER by the inventors herein, 
filed on even date herewith and assigned to the common 
assignee of this application. 




20 This application is further related to co-pending US 

Patent Application Serial No. g>f/ffg3 ^^/yIBM DOcktet No. 
AUS920011027US1) , entitled APPARATUS ' AND METHOD OF 
HIGHLIGHTING CATEGORIZED WEB PAGES ON A WEB SERVER by the 
inventors herein, filed on even date herewith and assigned 
25 to the common assignee of this application. 



- 1 - 



Docket No. AUS920011026US1 



BACKGROUND OF THE INVENTION 

1. Technical Field: 

The present invention is directed to a method and 
5 apparatus for managing bookmark folders. More specifically, 
the present invention is directed to an apparatus and method 
of automatically organizing bookmarked Web pages into 
categories . 

10 2. Description of Related Art: 

_ As is well known by now, the World Wide Web (WWW) or 

C= Internet is a system of servers that support documents 

formatted in Hyper Text Markup Language (HTML) . HTML 

B supports links to documents as well as to graphics, audio 

15 and video files. Links are references to documents from 

H within other documents. Links allow a user to easily jump 

from one document or Web page to another with just a click 
of a mouse. Thus, a link is a very useful Internet 
navigational tool. 

O 20 Another useful Internet navigational tool is a 

bookmark. A bookmark is a feature that is available in most 
Web browsers that allows a user to store Web addresses or 
URLs (Uniform Resource locators) of Web pages, that are to 
be later re-visited, into a folder (i.e., a bookmark 
25 folder) . (A Web browser is a software application that is 
used to locate Web sites and display Web pages.) Patent 
number 6,037,944 issued to Himmel et al. and entitled NAMED 
BOOKMARK SETS as well as patent number 6,208,995 Bl issued 
to the same inventors and entitled WEB BROWSER DOWNLOAD OF 
30 BOOKMARK SET describe how a bookmark is downloaded into a 
bookmark folder. The description in both patents is herein 
incorporated. 
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An active Web user may access and bookmark a great 
number of Web pages within a short span of time. Thus, to 
easily locate and access the bookmarked Web pages, the user 
has to arrange them in the folder in a logical manner. 
5 There are a number of available bookmark management tools 
that may be used to achieve this task. However, all of them 
require that the user actively manage the folder. 

For example, some software management tools allow a 
user to set up the bookmarked Web pages into a tree-like 

10 structure. That is, a user may create sub-folders into 
which related bookmarked Web pages may be stored. However, 
the user has to create the sub-folders and meticulously 
assign appropriate titles to each sub-folder. In addition, 
the user has to be careful to store each bookmarked Web page 

15 into the proper sub-folder. But even then, the user still 
has to be mindful that a sub-folder does not hold too many 
related bookmarked Web pages lest the purpose of arranging 
the pages into sub-folders be defeated. 

Furthermore, there may be times when Web pages 

20 bookmarked in different sub-folders may be related. Thus, 
it would be convenient if a user could store a copy of these 
related in another sub-folder with an appropriate name. 

What is needed, therefore, is a method and apparatus 
for combining bookmarks in different sub-foldres into a new 

25 sub-folder. 



- 3 - 



# 

Docket No. AUS920011026US1 



SUMMARY OF THE INVENTION 



The present invention provides a method and apparatus 
for combining bookmarks from different sub-folders into a 
5 new sub-folder. Using a keyword, the bookmarks from the 
sub-folders may be parsed. All the Web pages that contain 
the keyword may be stored into a new sub-folder. The 
keyword used in the search may be used as a name for the new 
sub-folder . 
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BRIEF DESCRIPTION OF THE DRAWINGS 

The novel features believed characteristic of the 
invention are set forth in the appended claims. The 
5 invention itself, however, as well as a preferred mode of 
use, further objectives and advantages thereof, will best be 
understood by reference to the following detailed 
description of an illustrative embodiment when read in 
conjunction with the accompanying drawings, wherein: 
10 Fig. 1 is an exemplary block diagram illustrating a 

distributed data processing system according to the present 
invention . 

Fig. 2 is an exemplary block diagram of a server 
apparatus according to the present invention. 
15 Fig. 3 is an exemplary block diagram of a client 

apparatus according to the present invention. 

Fig. 4 is a display of different categories on a Web 
portal . 

Fig. 5 is a representative graphical user interface 
20 (GUI) of a Web browser. 

Fig. 6 is a typical bookmark folder. 
Fig. 7 depicts a GUI for bookmarking a Web page. 
Fig. 8 depicts a GUI for bookmarking a Web page used by 
the present invention. 
25 Fig. 9 is a flow chart of a process that may be used to 

request categories in Web portals for use with the 
invention . 

Fig. 10 is a flow chart of a process that may reside on 
a Web portal to facilitate the invention. 
30 Fig. 11 is a flow diagram of a process that may be used 

to filter in or out bookmarked Web pages into a sub-folder. 
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Fig. 12 is a typical GUI to organize bookmarks in a 
bookmark folder. 

Fig. 13 is a GUI used to organize bookmarks in 
accordance with the invention. 
5 Fig. 14 depicts a GUI that may be used to link sub- 

folders . 

Fig. 15 depicts a bookmark folder used by the present 
invention. 

Fig. 16 is a flow chart of a process that may be used 
10 to display two or more linked sub-folders. 

Fig. 17 is a flow chart of a process that may be used 
to differentiate Web pages that have already been bookmarked 
from those that have not been bookmarked on a server. 
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DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT 

With reference now to the figures. Fig. 1 depicts a 
pictorial representation of a network of data processing 
5 systems in which the present invention may be implemented. 
Network data processing system 100 is a network of computers 
in which the present invention may be implemented. Network 
data processing system 100 contains a network 102, which is 
the medium used to provide communications links between 

10 various devices and computers connected together within 
network data processing system 100. Network 102 may include 
connections, such as wire, wireless communication links, or 
fiber optic cables. 

In the depicted example, server 104 is connected to 

15 network 102 along with storage unit 106. In addition, 
clients 108, 110, and 112 are connected to network 102. 
These clients 108, 110, and 112 may be, for example, 
personal computers or network computers. In the depicted 
example, server 104 provides data, such as boot files, 

20 operating system images, and applications to clients 108, 
110 and 112. Clients 108, 110 and 112 are clients to server 
104. Network data processing system 100 may include 
additional servers, clients, and other devices not shown. 
In the depicted example, network data processing system 100 

25 is the Internet with network 102 representing a worldwide 
collection of networks and gateways that use the TCP/IP 
suite of protocols to communicate with one another. At the 
heart of the Internet is a backbone of high-speed data 
communication lines between major nodes or host 
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computers, consisting of thousands of commercial, 
government, educational and other computer systems that 
route data and messages. Of course, network data processing 
system 100 also may be implemented as a number of different 
5 types of networks, such as for example, an intranet, a local 
area network (LAN) , or a wide area network (WAN) .. Fig. 1 is 
intended as an example, and not as an architectural 
limitation for the present invention. 

Referring to Fig. 2, a block diagram of a data 

10 processing system that may be implemented as a server, such 
as server 104 in Fig. 1, is depicted in accordance with a 
preferred embodiment of the present invention. Data 
processing system . 200 may be a symmetric multiprocessor 
(SMP) system including a plurality of processors 202 and 204 

15 connected to system bus 206. Alternatively, a single 
processor system may be employed. Also connected to system 
bus 206 is memory controller/cache 208, which provides an 
interface to local memory 209. I/O bus bridge 210 is 
connected to system bus 206 and provides an interface to I/O 

20 bus 212. Memory controller/cache 208 and I/O bus bridge 210 
may be integrated as depicted. 

Peripheral component interconnect (PCI) bus bridge 214 
connected to I/O bus 212 provides an interface to PCI local 
bus 216. A number of modems may be connected to PCI local 

25 bus 216. Typical PCI bus implementations will support four 
PCI expansion slots or add-in connectors. Communications 
links to network computers 108, 110 and 112 in Fig. 1 may be 
provided through modem 218 and network adapter 220 connected 
to PCI local bus 216 through add-in boards. 
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Additional PCI bus bridges 222 and 224 provide interfaces 
for additional PCI local buses 226 and 228, from which 
additional modems or network adapters may be supported. In 
this manner, data processing system 200 allows connections 
5 to multiple network computers. A memory-mapped graphics 
adapter 230 and hard disk 232 may also be connected to I/O 
bus 212 as depicted, either directly or indirectly. 

Those of ordinary skill in the art will appreciate that 
the hardware depicted in Fig. 2 may vary. For example, 
10 other peripheral devices, such as optical disk drives and 
the like, also may be used in addition to or in place of the 
hardware depicted. The depicted example is not meant to 
O imply architectural limitations with respect to the present 

invention. 

W 15 The data processing system depicted in Fig. 2 may be, 

CI for example, an IBM e-Server pSeries system, a product of 

f International Business Machines Corporation in Armonk, New 

y, York, running the Advanced Interactive Executive (AIX) 

-= operating system or LINUX operating system. 

□ 20 With reference now to Fig. 3, a block diagram 

^ illustrating a data processing system is depicted in which 

the present invention may be implemented. Data processing 
system 300 is an example of a client computer. Data 
processing system 300 employs a peripheral component 
25 interconnect (PCI) local bus architecture. Although the 
depicted example employs a PCI bus, other bus architectures 
such as Accelerated Graphics Port (AGP) and Industry 
Standard Architecture (ISA) may be used. Processor 302 and 
main memory 304 are connected to PCI local bus 306 through 
30 PCI bridge 308. PCI bridge 308 also may include an 
integrated memory controller and cache memory for processor 
302. Additional connections to PCI local bus 306 may be 
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made through direct component interconnection or through 
add-in boards. In the depicted example, local area network 
(LAN) adapter 310, SCSI host bus adapter 312, and expansion 
bus interface 314 are connected to PCI local bus 306 by 
5 direct component connection. In contrast, audio adapter 
316, graphics adapter 318, and audio/video adapter 319 are 
connected to PCI local bus 306 by add-in boards inserted 
into expansion slots. Expansion bus interface 314 provides 
a connection for a keyboard and mouse adapter 32 0, modem 

10 322, and additional memory 324. Small computer system 
interface (SCSI) host bus adapter 312 provides a connection 
for hard disk drive 326, tape drive 328, and CD-ROM drive 
330. Typical PCI local bus implementations will support 
three or four PCI expansion slots or add-in connectors. 

15 An operating system runs on processor 302 and is used 

to coordinate and provide control of various components 
within data processing system 300 in Fig. 3. The operating 
system may be a commercially available operating system, 
such as Windows 2000, which is available from Microsoft 

20 Corporation. An object oriented programming system such as 
Java may run in conjunction with the operating system and 
provide calls to the operating system from Java programs or 
applications executing on data processing system 300. 
"Java" is a trademark of Sun Microsystems, Inc. 

25 Instructions for the operating system, the object-oriented 
operating system, and applications or programs are located 
on storage devices, such as hard disk drive 326, and may be 
loaded into main memory 304 for execution by processor 302. 
Those of ordinary skill in the art will appreciate that 

30 the hardware in Fig. 3 may vary depending on the 
implementation. Other internal hardware or peripheral 
devices, such as flash ROM (or equivalent nonvolatile 
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memory) or optical disk drives and the like, may be used in 
addition to or in place of the hardware depicted in Fig. 3. 
Also, the processes of the present invention may be applied 
to a multiprocessor data processing system. 
5 As another example, data processing system 300 may be a 

stand-alone system configured to be bootable without relying 
on some type of network communication interface, whether or 
not data processing system 300 comprises some type of 
network communication interface. As a further example, data 

10 processing system 300 may be a Personal Digital Assistant 
(PDA) device, which is configured with ROM and/or flash ROM 
in order to provide non-volatile memory for storing 
operating system files and/or user-generated data. 

The depicted example in Fig. 3 and above-described 

15 examples are not meant to imply architectural limitations. 
For example, data processing system 300 may also be a 
notebook computer or hand held computer in addition to 
taking the form of a PDA. Data processing system 300 also 
may be a kiosk or a Web appliance. 

20 The present invention provides an apparatus and method 

of automatically assigning titles of sub-folders into which 
Web pages may be stored. The invention may be local to 
client systems 108, 110 and 112 of Fig. 1 or to the server 
104 or to both the server 104 and clients 108, 110 and 112. 

25 Consequently, the present invention may reside on any data 
storage medium (i.e., floppy disk, compact disk, hard disk, 
ROM, RAM, etc.) used by a computer system. 

There are a number of Web portals available today. A 
Web portal is a Web site that provides a broad array of 

30 resources and services such as e-mail, forums, search 
engines, on-line shopping malls as well as access to the 
Internet. These Web portals often have a search engine 
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also. Some of these Web portals are Yahoo (short for Yet 
Another Hierarchical Officious Oracle) , Metacrawler, 
AltaVista, Excite, Google, Looksmart, Webcrawler, ODP (Open 
Directory Project) . Most of the Web portals provide a 
5 directory that contains categorized Web pages. For example, 
when a user accesses the Open Directory Project Web site. 
Fig. 4 is displayed. Just about every word displayed in 
Fig. 4 is a category. As shown in the figure, there are 
categories (i.e., sub-categories) within categories. For 

10 instance, "Movies" is a sub-category within the "Arts" 
category. Note that, not all the categories listed on the 
site are shown in Fig. 4. 

The present invention uses the category classification 
in a Web portal to arrange bookmarked Web pages in the 

15 bookmark folder. When a user selects a link or Web page to 
bookmark, a client program on the user' s machine may request 
from a server program of a default Web portal the category 
in which the link or Web page is located. Or, the client 
program may request the categories in batch after a pre- 

20 determined time interval. When the category is received, a 
sub-folder is created and the category is used as the name 
of the sub-folder if it does not already exist. The 
bookmarked Web page is then stored into the sub-folder. 

In the event that the link or Web page is not found in 

25 any of the categories of the default Web portal, the 
algorithm on the user' s machine may so notify the Web portal 
administrator. When the Web portal administrator classifies 
the Web page into a category, a message may be sent to the 
user' s machine with the category in which the Web page is 

30 now located. At that point, a sub-folder for the category 
may be created on the user' s machine into which the 
bookmarked Web page may then migrate. 
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As usual, a user may change the name or title of a 
category or folder at will. Likewise, a user may merge one 
sub-folder/category into another and create new sub- 
folders/categories . 
5 Additionally, a user may link one category/sub-folder 

to another. For example, suppose a user links sub-folder 
"B" to "A". Then, when a user accesses sub-folder "A", all 
the bookmarks in sub-folder "A" as well as those in sub- 
folder "B" will be displayed. If however, the user accesses 
10 sub-folder "B", only the bookmarks in sub-folder "B" will be 
displayed. 

A user may further create a new category by simply 
merging two or more categories or merging two or more 
categories and filtering the bookmarked Web pages with a 

15 keyword or phrase. For instance, suppose a user wants to 
create a category/sub-folder named "Austin" in which 
bookmarks of other folders may be stored. If the user uses 
"Austin" as a keyword to search the merged bookmark sub- 
folders, the invention will parse all the bookmarked Web 

20 pages in the merged sub-folders for that reference. Any 
bookmarked Web pages with the Austin reference will be 
duplicated and stored into the category/sub-folder and 
Austin may be used as the name of the sub-folder. Note that 
bookmarks may be filtered out instead of being filtered in 

25 as in the example above. For instance, instead of 
bookmarking all the Web pages that contain the Austin 
reference in the sub-folder, the algorithm may be designed 
to bookmark all the references that do not contain the 
Austin reference. 

30 In addition, Boolean searches may also be performed. 

For instance, a user may search the sub-folders for both 
Austin and IBM. Furthermore, the user may decide to 
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bookmark Web pages that contain only the IBM reference since 
the Web pages with the Austin reference will have already 
been in the Austin sub-folder. Thus, different search 
algotrithms may be used. 
5 Note also that in the examples above, the entire 

bookmark folder may be searched instead of a few sub- 
folders . 

Moreover, the user may set options not to display an 
empty category/sub-folder. Additionally, the user may set 

10 the options not to display contents of a category/sub-folder 
with less than N bookmarked pages in the sub-folder but 
rather to display the content in the parent directory 
instead. For example, suppose there is one bookmark in sub- 
folder CRAFTS and sub-folder CRAFTS is under parent 

15 directory ARTS, if N is equal to 3, the bookmark may be 
shown under the ARTS directory. In that case, the user need 
not go down to the sub-folder to access the Web page 
bookmarked in the CRAFTS directory but may do so from the 
parent directory. Note that above N may be either a user- 

20 defined integer or a default integer. 

Fig. 5 is a representative graphical user interface 
(GUI) of a Web browser. Not all items in the GUI are shown 
and only the items of importance to the invention are given 
a reference numeral. When a Web browser is activated and a 

25 Web page is accessed, the content of the page is displayed 
in area 515, the address or URL of the page is displayed in 
address box 500. To bookmark a page, the bookmark folder 
has to be opened. In Netscape Navigator, a user has to 
click once on a bookmark icon and in Internet Explorer the 

30 user has to click once on a Favorites icon to open the 
bookmark folder. In this particular example, Internet 
Explorer is used. However, it should be understood that any 



- 14 - 



Docket No. AUS920011026US1 



other Web browser having the bookmark feature may be used 
with the invention. In any case, when the bookmark folder 
is opened. Fig. 6 is displayed. When a user asserts "add to 
Favorites", Fig. 7 is displayed. In name box 700 is 
5 displayed a default name associated with the URL. If the 
user so wants, the user may replace the default name by 
another name of the user's liking. When done, ok button 705 
can be asserted to bookmark the page, or cancel button 710 
can be asserted to close Fig. 7 without bookmarking the 
10 page. 

Fig. 8 is a depiction of Fig. 7 with an added function. 
The added function is a categorize bookmark function that 
can be accessed using categorize bookmark button 815. Name 
box 800, OK button 805 and cancel button 810 have the same 

15 purpose as name box 700, OK button 705 and cancel button 710 
in Fig. 7. When the user asserts categorize bookmark button 
815, a search will be sent to the Web portals to determine 
in which category the Web page to be bookmarked is located. 
When the category is returned, another check may again be 

20 done to determine whether there is already a sub-folder by 
, that name. If so, the Web page will be stored in the sub- 
folder. If not, a sub-folder will be created and the 
category will be used as the name of the sub-folder. Then 
the Web page will be stored within the sub-folder. 

25 Fig. 9 is a flow chart of a process that may be used to 

request categories in Web portals for use with the 
invention. The invention starts when the Web browser is 
activated (step 900) . A check will continuously be made to 
determine whether a Web page is being bookmarked. If so, a 

30 search for that Web page will be made on the default Web 
portal (steps 905, 910 and 915) . If the Web page is found, 
depending on the implementation, the client computer may 
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request that the category in which the Web page is found be 
provided or the server or Web portal may automatically 
convey the category to the client system (step 935). Then, 
a check will be made on the client system to determine 
5 whether there exists a sub-folder having the name of the 
category. If so, the bookmark for that Web page will be 
stored in the existing sub-folder. If not a sub-folder by 
that name may be created in which the bookmark may be stored 
(steps 935, 940, 945 and 950) . 

10 If the Web page is not found in the default Web portal, 

the default Web portal may do a search on other Web portals 
for the Web page. If the Web page is found on one of the 
servers searched, the default Web portal may use a cross- 
reference map to properly assign the Web page into one of 

15 its own categories. The category into which the Web page is 
assigned may then be downloaded to the client that requested 
the search. If the Web page is not found in any category of 
the Web portals searched, a note may be left to the 
administrator of the default Web portal to assign the Web 

20 page into a category. 

In that case, the Web page will be stored into a 
default sub-folder. When the administrator has categorized 
the Web page, a note may then be sent to the client system 
with the category in which the Web page is now located. At 

25 that time, the client may search the bookmark folder to 
determine whether there already exists a sub-folder by that 
name. If so, the bookmark will be moved into the sub- 
folder. If not, one will be created to store the bookmark 
(steps 920, 925, 930, 940, 945 and 950) . Note that to 

30 determine which bookmark from the default folder to use, the 
server may download along with the category the URL of the 
Web page. The downloaded URL may then be compared with the 
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URLs of the Web pages bookmarked in the default sub-folder. 
In anycase, when the bookmark is put into the category, the 
user may be notified. 

Note also that when a user is bookmarking a Web page, a 
5 search may also be performed. Using the example of the 
Austin filtration described above, when the user decides to 
bookmark a Web page, a search for Austin may be performed. 
If the Web page contains a reference to Austin, the Web page 
may be stored not only in the appropriate category but in 

10 the Austin sub-folder as well. 

Fig. 10 is a flow chart of a process that may reside on 
a Web portal to facilitate the invention. Whenever the 
server on which the program is installed is running the 
process is also running (step 1000). When the server 

15 receives a search for a Web page, it searches its 
directories for the Web page. If the Web page is not found, 
it may do a search on other Web portals for the Web page. 
If the Web page is found on one of the Web portals, the 
category in which the Web page is located may be mapped to a 

20 category of the default Web portal. The Web portal may 
store the Web page in the category that is mapped to the 
category in which the Web page was found and the default Web 
portal's category may then be downloaded to the client 
(steps 1000, 1005, 1010, 1015, 1020, 1025, 1030 and 1035) . 

25 If the Web page is not found in any categories of the 

Web portals searched, the administrator may be notified that 
the Web page needs to be categorized. It will then send a 
note to the computer requesting the search that the Web page 
has not been categorized (steps 1005, 1010, 1015, 1020, 

30 1025, 1040 and 1045) . If the Web page is found in a 
category, the category will be returned to the computer 
system that has requested it (steps 1015 and 1050) . 
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Note that depending on the implementation, the search 
may stop as soon as the Web page is found in a category or 
may continue. If the search continues, then all the 
categories in which the Web page was found may be returned 
5 to the computer system. The computer system may either use 
the first category of the ones returned or may request that 
the user chooses one or all of the categories. If all the 
categories are used, a number of sub-folders equals to the 
number of categories returned will be created into which the 

10 bookmark to the Web page is to be stored. Each category 
will be used as a name to one of the sub-folders. 

Fig. 11 is a flow diagram of a process that may be used 
to filter in or out bookmarked Web pages into a sub-folder. 
The process starts when a search request is initiated on the 

15 user's computer system to search sub-folders that contain 
Web pages for a provided keyword or phrase (step 1100). 
When this occurs, a check will be made to determine whether 
the sub-folders in which to search are provided. If they 
are provided, all the bookmarked Web pages in the sub- 

20 folders will be searched using the provided keyword or 
phrase. If sub-folders are not provided, the entire 
bookmark folder will be searched. After obtaining the 
result of the search, a sub-folder will be created and the 
result will be stored therein. If the search is to filter 

25 out the Web pages that contain the referenced keyword or 
phrase, the result will contain all the Web pages that do 
not contain the referenced key word or phrase. If, on the 
other hand, the search is to filter in the Web pages that 
contain the referenced keyword or phrase, the result will 

30 contain all the Web pages in which the referenced keyword or 
phrase was found. The keyword or phrase provided may be 
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used as the name of the newly created sub-folder (steps 
1100, 1105, 1110, 1115, 1120, 1125 and 1130) . 

Note that to do the search, the Web pages will have to 
be accessed and parsed for the keyword or phrase. All that 
may be done in the background (i.e., transparent to the 
user) . Note also that a method of performing a search is 
not disclosed as performing searches is well known in the 
field. 

To link two or more sub-folders together, a user has to 
assert the organize favorites feature 610 of Fig. 6. When 
this feature is asserted, the GUI in Fig. 12 is displayed. 
Buttons 1200 - 1215 and 1225 are self-explanatory. All sub- 
folders in the bookmark folder, including bookmarks that are 
not in a sub-folder, are displayed in area 1220. The 
invention uses an added button to link two or more sub- 
folders together. 

Linking a first sub-folder to a second sub-folder is in 
essence copying the bookmarks in the first sub-folder into 
the second sub-folder. The copied bookmarks should be 
marked to distinguish then from the bookmarks originally 
stored in the second sub-folder. One way of marking the 
bookmarks is to put them under a title. The title may be 
the name of the first sub-folder. Thus, when the second 
sub-folder is accessed both the bookmarks originally stored 
in the folder and the bookmarks stored in the second folder 
may be displayed in a distinguishing manner. 

Fig. 13 is an Organize Favorites GUI with the added 
button. Again buttons 1300 - 1315 and 1325 are self- 
explanatory. Area 1330 is used to list all the sub-folders 
in the bookmark folder. Link folders 1330 is used to link 
two or more folders together. When this button is asserted, 
a window may pop open to prompt the user to select which 
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sub-folder or sub-folders that the user wants to have linked 
and which sub-folder the selected sub-folder or sub-folders 
should be linked to. 

Fig. 14 depicts a GUI that may be used to link the sub- 
5 folders. In box 1400, a user may choose the sub-folders 
that the user wants to link by entering their name in name 
boxes 1405 - 1415. In name box 1450 of box 1450, the user 
may enter the name of the sub-folder to which the sub- 
folders entered in box 1400 are to be linked. All the sub- 
10 folders in the bookmark folder, including bookmarks that are 
Q not in sub-folders, are displayed in area 1425. 

^ Consequently, the user may alternatively center the focus of 

the application on one of name boxes 1405 - 1415 and 1420 
and click on a sub-folder listed in area 1425 to enter the 

Ly 

-ifl 15 name of the sub-folder in the name box in focus. When done 
^ the user may assert OK button 1430 and close the window by 

|=i asserting close button 1430. 

Fig. 15 is a GUI that may be used to display the linked 
i_y sub-folders. When the bookmark folder is accessed, a list 

H 20 of the sub-folders as well as of the bookmarks that are not 
in a folder is displayed. Bookmarks, bookmarkb ... is a list 
of bookmarked Web pages that is not a sub-folder. sub- 
folder2 and sub-folders are linked to Sub-folderi. 

Fig. 16 is a flow chart of a process that may be used 
25 to display two or more linked sub-folders. The process 
starts as soon as the Web browser is activated (step 1600) . 
Then a check is continuously being made to determine whether 
a sub-folder is being accessed. If so, another check is 
made to determine whether other sub-folders are linked to 
30 the sub-folder being accessed. If not, the bookmarks stored 
in the sub-folder being accessed are displayed (steps 1605, 
1610 and 1615) . If there are other sub-folders linked to 
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the sub-folder being accessed then the bookmarks in the sub- 
folder being accessed as well as the bookmarks stored in the 
sub-folders that are linked to the sub-folder being accessed 
are all displayed (step 1620) . 
5 In order to distinguish the bookmarks from the 

different sub-folders, the bookmarks may be organized in 
groups based on the sub-folders in which they are stored. 
Each group of bookmarks may then be displayed in a different 
color. Alternatively, the sub-folders may be displayed as 
10 parents under which their children bookmarks may be 
displayed . 

The present invention has been described using a client 
system. However, the invention will work as well on a 
server system. Specifically, if a user has an account with 

15 one of the Web portals that allows a user to have a bookmark 
folder, the user may arrange bookmarked Web pages in the 
bookmark folder in categorized sub-folders. In this case, 
all the algorithms described above will reside on the server 
system. In addition, the user may give others access to the 

20 bookmark folder. In this case, these other users should 
also have an account with the Web portal and the Web portal 
should also have a permission feature allowing the user to 
do so. As the user is bookmarking the Web page, the user 
may designate the other users that may also access the 

25 bookmarked Web page. Hence, only bookmarked Web pages with 
the permission feature enabled may be accessed. 

In addition, when the user accesses the directory of 
the Web portal, all the Web pages that are in the user's 
bookmark folder may be displayed in a different color to 

30 alert the user that the Web pages in the directory have 
already been bookmarked. 
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Fig. 17 is a flow chart of a process that may be used 
to differentiate Web pages that have already been bookmarked 
from those that have not been bookmarked on a server. The 
process starts as soon as the user accesses a Web portal 
5 (step 1700) . The program then collects the URLs of all the 
bookmarks in the user's bookmark folder. Note that the 
bookmark folder may reside either on the client or on the 
server or on both the client and server. The collected URLs 
are compared with the URLs of the Web pages in the 

10 directory. All the Web pages in the directory having the 
same URLs as the URLs of the collected Web pages will be 
displayed in a highlighted fashion in the directory (steps 
1705, 1710 and 1715) . Note also that here highlighted 
fashion encompasses any manner of distinguishing already 

15 bookmarked Web pages from those that have not been 
bookmarked . 

The description of the present invention has been 
presented for purposes of illustration and description, and 
is not intended to be exhaustive or limited to the invention 

20 in the form disclosed. Many modifications and variations 
will be apparent to those of ordinary skill in the art. The 
embodiment was chosen and described in order to best explain 
the principles of the invention, the practical application, 
and to enable others of ordinary skill in the art to 

25 understand the invention for various embodiments with 
various modifications as are suited to the particular use 
contemplated . 
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